package com.example.form.dao;

import com.example.form.model.Article;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface ArticleMapper {
    int insert(Article row);

    int insertSelective(Article row);

    Article selectByPrimaryKey(Long id);

    int updateByPrimaryKeySelective(Article row);

    int updateByPrimaryKeyWithBLOBs(Article row);

    int updateByPrimaryKey(Article row);
    /**
     * 主⻚中显⽰的帖⼦列表以发布时间降序排列
     *
     * @return 帖⼦列表
     */
    List<Article> selectAll ();

    /**
     * 根据版块Id查询帖⼦列表以发布时间降序排列
     *
     * @param boardId 版块Id
     * @return 帖⼦列表
     */
    List<Article> selectByBoardId (Long boardId);

    /**
     * 根据Id查询帖⼦详情
     * @param id 帖⼦Id
     * @return 帖⼦详情(加了用户id和板块id的article类)
     */
    Article selectDetailById(Long id);

    /**
     * 根据⽤⼾Id查询帖⼦列表以发布时间降序排列
     * @param userId 用户id
     * @return  帖子列表
     */
    List<Article> selectByUserId(@Param("userId") Long userId);
}